#include <iostream>
#include <queue>
#include <map>
#include <unordered_map>
#include <vector>
#include <algorithm>
#include <cmath>
#include <string>
#include <cstring>
#include <set>
#include <unordered_set>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int,int> pii;
const int INF=0x3f3f3f3f;
const int N=1e4+10,M=1e11;
string s[N];
bool cmp(string a,string b)
{
	string a1=a+b;
	string b1=b+a;
	return a1<b1;
}
int main()
{
	int n;
	cin>>n;
	for(int i=0;i<n;i++)
	{
		cin>>s[i];
	}
	sort(s,s+n,cmp);
	//for(int i=0;i<n;i++)
	//{
	//	cout<<s[i]<<' '; 
	//}
	//cout<<endl;
	for(int i=0;i<n;i++)
	{
		cout<<s[i];
	}
	

	return 0;
}

